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Since July 2008, the Multidisciplinary Analysis & Optimization Working Group (MDAO WG) 
of the Systems Analysis Design & Optimization (SAD&O) discipline in the Fundamental 
Aeronautics Program’s Subsonic Fixed Wing (SFW) project completed one major milestone, 
“Define Architecture & Interfaces for Next Generation Open Source MDAO Framework” 
Milestone (9/30/08), and is completing the Generation 1 Framework validation milestone, 
which is due December 2008. Included in the presentation are: details of progress on 
developing the Open MDAO framework, modeling and testing the Generation 1 Framework, 
progress toward establishing partnerships with external parties, and discussion of additional 
potential collaborations. 
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• GOAL 

- Advance the state of the art of physics-based multidisciplinary 
analysis & optimization for both conventional & unconventional 
vehicles. 

• OBJECTIVES 

- Focus on Subsonic Fixed Wing and Supersonics applications, 
but develop capabilities that can support all flight regimes. 

- Improve current MDAO tools and integration techniques. 

- Establish the groundwork and provide an open source next 
generation MDAO capability for far-term activities. 

- Collaborate with the MDAO community in industry, academia, 
and other government agencies throughout the development 
process to benefit all parties. 
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OpenMDAO Status Highlights 



• Completed initial “ Next Generation Open Source MDAO 
Framework Architecture Document ” (9/30/08 milestone) 

• Implementing core OpenMDAO framework objects using 
python 

• Held python training at LaRC and scheduled another session at 
GRC 


• Evaluating variable fidelity objects from M4 Engineering SBIR 

• Implementing ‘toy” distributed simulation to learn about python 
distributed objects 


M OpenMDAO Status Highlights (continued) 


• Prepared to request Requirements feedback 

• Revisiting MDAO Test Cases (interfaces and testing) 

• Researching what’s needed to launch OpenMDAO 

external website 


• Evaluating & setting up development tools (Bazaar, 
T rac) & processes 



OpenMDAO Status Highlights (continued) 


• Continuing to develop Problem Formulation Prototype 
using python 


• Presented Papers at AIAA/ISSMO Multidisciplinary 
Analysis and Optimization Conference in Victoria, CA : 

- “ The Development of an Open-Source Framework for Multidisciplinary 
Analysis and Optimization” by Moore, Naylor, & Gray 

- ‘‘Reliability Based Design Optimization of a Composite Airframe 
Component” by Patnaik, Pai & Coroneos 


Outreach: Collaboration 



• Examples of parties who have indicated interest: 

- NASA (Constellation) 

- DoD 

• Computational Research & Engineering Acquisition Tools & Environments 
(CREATE) Program 

• AFRL: Air Vehicles & Propulsion Directorates 

- DoE 

• Sandia Labs: Design Analysis Kit for Optimization and Terascale Applications 
(DAKOTA) 

- Industry: Boeing, Lockheed, GE 

- Academia: Georgia Tech, Stanford, University of Toronto 

• Example NRA&SBIR: 

- Subsonic Fixed Wing SBIR 

• Multidisciplinary Optimization Object Library (M4 Engineering) 

- Supersonics NRA 

• Control of Boundary Representation Topology in MDAO (MIT) 
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Outreach: Collaboration Ideas 



• Requirements 

- Feedback on latest Requirements: suggest changes & additions 

- Propose additional Use Cases 

• Testing 

- Test Cases 

- User feedback 

- Beta testers 

• Identify areas of functionality to share & contribute 

- Geometry 

- Uncertainty Analysis 

- Optimization 

- Framework 

- Discipline codes 


Outreach: Partnerships 



• Identify partners interested in establishing Space 
Act Agreements or Interagency Agreements 

• Follow-up with interested parties, establish 
agreements, and work as a group 

• If your company/organization is interested in this 
MDAO activity, contact Cynthia Naiman 


Next Steps 



Sub Tasks 

Activities 

IQ 

FY09 

2Q 

FY09 

3Q 

FY09 

4Q 

FY09 

Requirements 

•Document feedback on discipline requirements 





•Allocate groupings of requirements to be completed by 4QFY10 


- 



•Identify, define, & document test cases 





GEN1 Validation 

•Exercise GEN1 Capability for Commercial Transport 

wmmJL 




•Document validation results in GEN1 report 





GEN2 HWB Toolset 

•Identify HWB configuration to use for 3QFY10 milestone 





•Define GEN2 validation plan 





•Determine what discipline codes are needed 


— 



•Identify which codes need to be integrated into ModelCenter 


— 



•Identify needed code improvements and/or integration techniques 


— 



•Implement code & integration improvements 









/\ Planned Milestone 


Timeline 
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Next Steps (continued) 



Sub Tasks 


Activities 


IQ 

FY09 


2Q 

FY09 


3Q 

FY09 


4Q 

FY09 


Alpha OpenMDAO 
Framework 


Outreach 


•Continue prototyping using python 

•Offer python training 

•Set up development environment 

•Research what is needed to setup an open source project 

•Setup technical infrastructure and communications mechanisms 

•Define processes for daily development & release distribution 

•Prepare website and documentation for open source public release 

•Address export control & legal issues 

•Implement core framework classes 

•Solicit feedback on requirements from potential external partners 
•Host meetings with interested parties (industry, academia, gov) 
•Pursue potential collaboration in Open Source MDAO community 
•Leverage NRA& SBIR MDAO efforts 
•Present status at SAD&O Technical Working Group Meetings 


Timeline 
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Conclusion 



• Physics-based MDAO is a critical national need and 
is an extremely difficult challenge 

• 2-Path approach benefits near- and long-term needs 

• User involvement throughout the development life- 
cycle is critical 

• Partnering with industry, academia, and other 
government agencies is essential to realize MDAO 
vision 


Additional Information Available 



• See SAD&O Website: 

- http://mdao.qrc.nasa.gov/SADO-TWG/index.html 

• Userid “guest" 

• Password “sado” 


• Contact Cynthia Naiman 

- Cvnthia.G.Naiman@nasa.gov 

- 216 - 433-5238 
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“Toy” Simulation to Explore Distributed Object Communication 



• Intended to provide semi-realistic environment for experimenting with different technologies. 

• NOT intended as a prototype for the real framework, or something evolving into the real 
framework 

• Supports typical data and process flows. 

• Example problem is nested optimization of AXOD (AXial Off Design: a meanline axial turbine 
code that can generate off-design maps) input parameters to match a set of data. 

• A genetic optimizer is used to set starting points for gradient optimizers distributed to nodes of 
local GX cluster. 

• GX has 220 AMD Opteron (64-bit) processors connected via Infiniband running Debian 
Linux. It's local to GRC. 

• Has experimental support for driving wxPython and web GUIs from the same GUI code. 

• Matplotlib does the plotting. 

• Distributed objects 

- Need support for distributing sub-models (for optimization, etc) as well as remote objects within a single 
model. 

‘Twisted’ package provides basic networking support for multiple protocols. Twisted is a stable, widely 
used package. Twisted depends on various sub-packages like zope.interface, Crypto, OpenSSL. 
Twisted is used for HTTP, OpenSSL for HTTPS and RPyCS. 

- ‘RPyC’ package provides transparent support for distributed objects. Not an exact fit for our 

requirements. RPyC is a new, evolving project. A modified RPyC does the distributed object 
communication. 

• Beginning to explore how M4 work can be incorporated into a framework similar to that defined 
in the architecture document. 

- Numeric, numarray, numpy, scipy get pulled-in for M4 objects as well as matplotlib. 
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“Toy” 

Simulation 






OpenMDAO Website Concept 



Scenario 1: 

The typical NASA open 
source website. 


Scenario 2: 
(Desired) 
Full open source 
community. 




OpenMDAO Life Cycle Process 



^ ACCEPTED- Email sent to Dev Lead, SCM & Submitter 


Email sent to SCM 
& Submitter 


OpenMDAO Life Cycle Process (cont’d) 


Assign CR to team member 

^ ASSIGNE D - Email sent to assigned team member 


Assignee opens 
branch 


WORKING - Email sentto SCM & Submitter 


Major Changes 
Required 


Assignee works 
CR 


Assignee submits 
changes for review 


REVIEWING 

- Code 


REWORKING 

- Code 

Email sent to Assignee 


Assignee sends 
associated document 
changes to Tech Writer 



Tech Writer works 
documentation 


READY_MERGE - Email sentto SCM.V&V & Assignee 


Release process 



RELEASED 

Email sentto Submitter &Team 
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Problem Formulation Tool Prototype 



15 Piototype Problem Formulation Tool 

File Edit View 


Uii 


Desired Analysis Results 


yialH 


1 i . 






This is the prototype's statusbar 
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Backup Charts 


Role of OpenMDAO.org Website 


News/Information 
Source Code & Distributions 

- Read-only access to framework and open-source plug-ins to the general public 

• Changes to the framework come through NASA gatekeeper 

• Closed-source plug-ins (e.g. NPSS) have restricted access 

- Anyone can write a custom plug-in, and since it does not impact the framework source, 
it needn’t go through a gatekeeper 

• Custom components and variable types that are written can be kept to oneself or shared with 
the community 

• Custom components that are shared could be rated by the community 

• Highly-rated custom components could be added to OpenMDAO standard lib 

Documentation 

- OpenMDAO User Guide 

- OpenMDAO Developer Guide 

- Use Case ”How To” Guide 
Discussion Forums 
Submission of Defects 
Proposals for Enhancement 
Adding New Developers 


Outreach: NRA and SBIR Activities 



• Subsonic Fixed Wing NRAs 

- Develop parametric blade geometry modeler (AVETeC/University of Cincinnati) 

- “System Analysis & Design Approach to the Hybrid Wing/Body Aircraft” (AVID LLC) 

- Improve structural modeling, meshing and rapid grid morphing capabilities within Vehicle Sketch Pad (Cal 
Poly/Phoenix Integration/J R Gouldemans) 

- “Enhanced Modeling & Analysis for Emission Prediction” (Georgia Tech/ASDL) 

- "Adv Multidisciplinary Optimization T echniques for Efficient Subsonic Aircraft Design” (MIT/ 
Stanford/Purdue/Boeing) 

• Supersonics NRAs 

- “High Fidelity MDO: Software Infrastructure & Application to Supersonic Aircraft” (M4 Engineering/Phoenix 
Integration) 

- “Control of Boundary Representation Topology in MDAO” (MIT) 

- “Multifidelity Analysis and Design Methods for Supersonic Aircraft” (Stanford/MIT) 

• Subsonic Fixed Wing SBIRs 

- Cumulative Metamodelingw/Uncertainty Estimation (Nielsen Engineering) 

- Advanced Modeling Concepts for Conceptual Design (NextGenAeronautics) 

- Multidisciplinary Optimization Object Library (M4 Engineering) 

- Multi-Disciplinary, Multi-Fidelity Design Environment (Phoenix Integration) 

Details on any NRA & SBIR efforts are available. 
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Example: Optimization Using a Cluster 



k l 
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1. User requests simulation to run. 



Example: Optimization Using a Cluster 


gxOO 


Simulation GUI 


Component API 
Distributed Objects 
Network Layer 
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1. User requests simulation to run. 

2. Genetic optimizer replicates sub-model. 




GradientOpt 


AXOD 


1. User requests simulation to run. 

2. Genetic optimizer replicates sub-model. 

3. Genetic optimizer allocates resources. 
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Example: Optimization Using a Cluster 




1. User requests simulation to run. 

2. Genetic optimizer replicates sub-model. 

3. Genetic optimizer allocates resources. 

4. Genetic optimizer loads copies of sub-model. 



z 

o 

in' 

o 

o 



gx03 


e-t- 

o 

cr 

C 

r-h- 

CD 


!=*- 

GradientOpt 



4 ► 


a- 

CD 

£3 





r 

fa 

'< 

o 

r-h- 

> 

hd 


AXOD 




o 

r-t- 

m 

1— H 







z 

o 

in 

o 

o 



gx04 


if 

o 

<T 

C 

r- K 

CD 

| 

3 


GradientOpt 



4 ► 


p. 

CD 

£3 





r 

p 

o 

r-K 

> 


AXOD 




o 

c-t- 

m 

h— ( 







Example: Optimization Using a Cluster 


gxOO 


Simulation GUI 


Component API 


Distributed Objects 
Network Layer 


1. User requests simulation to run. 

2. Genetic optimizer replicates sub-model. 

3. Genetic optimizer allocates resources. 

4. Genetic optimizer loads copies of sub-model. 

5. Genetic optimizer starts gradient optimizers. 
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Example: Optimization Using a Cluster 
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1. User requests simulation to run. 

2. Genetic optimizer replicates sub-model. 

3. Genetic optimizer allocates resources. 

4. Genetic optimizer loads copies of sub-model. 

5. Genetic optimizer starts gradient optimizers. 

6. Gradient optimizers perform AXOD runs. 





Incremental Software Development 



Submit Change Requests: 
Requirement, Enhancement, Defect 


All phases are 
iterated as 

needed. 


Developers & Leads 


Project Management 


Evolutionary Delivery Schedule 




Top 10 Risks 




Metrics Collection & Analysis 




Lessons Learned 




Improve Processes 





Analyze 


Run Unit & 
Regression 
Tests 


Code Inspections & Peer Reviews 


Customer/User involvement in all 
phases of development is critical. 


Verification & 
Validation: Run 
Regression Tests 


Software 
Configuration: 
Merge, Test, 
Generate Release 


Daily Builds 
Increments 
Full Versions 

















